/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package br.edu.unifei.portal.dao;

import br.edu.unifei.portal.modelo.Pessoa;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.Query;

/**
 *
 * @author Cristiano Affá
 */
public class PessoaDao {

    private EntityManager em;

    public PessoaDao(EntityManager em) {
        this.em = em;
    }

    public void create(Pessoa pessoa) {
        em.getTransaction().begin();
        em.persist(pessoa);
        em.getTransaction().commit();
    }

    public void update(Pessoa pessoa) {
        em.getTransaction().begin();
        em.merge(pessoa);
        em.getTransaction().commit();
    }

    public void delete(String cpf) {
        em.getTransaction().begin();
        Pessoa c = findPessoa(cpf);
        em.remove(c);
        em.getTransaction().commit();
    }

    public Pessoa findPessoa(String cpf) {
        return (Pessoa) em.createQuery(
                "from Pessoa where cpf = '" + cpf + "'").getSingleResult();
    }

    public List<Pessoa> findAllPessoa() {
        return em.createQuery("from Pessoa").getResultList();
    }

    public List<Pessoa> findPagePessoa(int max, int first) {
        Query query = em.createQuery("from Pessoa");
        query.setMaxResults(max);
        query.setFirstResult(first);
        return query.getResultList();
    }

    public long getCountPessoa() {
        Query query = em.createQuery("from Pessoa");
        return (Long) em.createQuery(
                "select count(*) from Pessoa").getSingleResult();
    }
}
